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APPARATUS AND METHOD FOR 
INCREASING A DIGITAL CAMERA IMAGE 
CAPTURE RATE BY DELAYING IMAGE 
PROCESSING 

CROSS-REFERENCE TO RELATED 
APPLICATIONS 

I1iis application relates to co-pending U.S. patent appli- 
cation Ser. No. 08/355,031, entitled "A System and Method 
For Generating a Contrast Overlay as a Focus Assist for an 
Imaging Device " filed on Dec. 13, 1994, and also relates to 
co-pending U.S. patent application Ser. No. 08/588,210, 
entitled "Apparatus and Method for Rotating the Display 
Orientation of a Captured Image," filed on Jan. 19, 1996. 

BACKGROUND OP THE INVENTION 

1. Field of the Invention 

The present invention relates generally to a method and 
apparatus for managing digital image data. More 
particularly, the present invention is an apparatus and 
method for increasing the image capture rate of a digital 
camera by delaying image processing and compression. 

2. Description of the Background Art 
Still-cameras are often required to capture images at rates 

which vary depending on their selected photographic tar- 
gets. For example, during a fast-moving sporting event, 
still-cameras may be required to capture a series of images 
during a relatively short time period. Thus, an important 
still-camera performance feature is the capture rate for 
successive sets of image data. 

Another important still-camera performance feature is the 
number of captured images that can be stored in the cam- 
era's finite memory. To maximize the image-carrying capac- 
ity of digital still-cameras, it is desirable to compress the 
images prior to storage. Conventional digital cameras typi- 
cally perform image processing on the raw image data and 
then use a high-quality image compression routine (such as 
JPEG) to compress the image data. 

Photographers, however, may want to capture another 
image before the camera has completed the time-consuming 
image processing and compression of raw image data. 
Therefore, the above processing and compression technique 
can effectively lower the successive image capture rate. 

One common approach for minimizing the image pro- 
cessing and compression time is through the use of custom- 
designed Application Specific Integrated Circuits (ASICs). 
Typically, up to three relatively expensive ASICs may be 
required to perform the image processing and compression 
operations. While such ASIC-based cameras perform the 
required image processing and compression operations very 
quickly, their increased cost may render such cameras less 
attractive to the mainstream consumer market. 

To make the digital cameras more affordable, manufac- 
turers have replaced many of the costly ASICs with func- 
tionally equivalent software-based routines. The software- 
based routines may be stored within standard ROM chips 
and they can also be readily updated by rewritmg a portion 
of the software. Software-based cameras, however, typically 
require an inordinately long time to perform the image 
processing and compression operations. This results in 
slower successive image capture rates and limits the mar- 
ketability of the software-based digital still-cameras. 

Therefore, what is needed is an apparatus and method that 
enables a relatively low -cost, software-based digital camera 
to attain higher successive image capture rates. 
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SUMMARY OF TI-IE INVENTION 
The present invention is a method and apparatus for 
increasing the image capture rate of a digital'camera by 
delaying image processing and compression of the captured 

5 image data. In the present invention, an imaging device 
captures an image in response to an image capture request 
and responsively produces corresponding raw image data 
which is temporarily stored into a frame buffer. 

A first RAM spooler then typically transfers the raw 

10 image data to a RAM disk. A first flash spooler next transfers 
the raw image data from the RAM disk to a flash memory 
which preferably is a removable flash disk. An image 
processor processes and compresses the raw data and may 
directly store the compressed data to the RAM disk, or 

^5 alternately, a second RAM spooler may store the com- 
pressed image data into the RAM disk. A second flash 
spooler then transfers the compressed image data from the 
RAM disk to the flash memory. 

The present invention uses a set of priorities designed to 
maintain the frame buffer in a condition to receive new 
image data firom the imaging device. Therefore, spooling 
raw data from the frame buffer to the RAM disk has the 
highest priority, spooling raw data from the RAM disk to the 
flash memory has the second highest priority, processing and 
compressing the raw data from the flash memory has the 
third highest priority, spooling the compressed data into the 
RAM disk has the fourth highest priority, and spooling the 
compressed data from the RAM disk to the flash memory 
has the lowest priority. 

30 BRIEF DESCRIPTION OF THE DRAWINGS 

.FIG. 1 is a block diagram showing a preferred embodi- 
ment of an apparatus for increasing a digital camera image 
capture rate by delaying image processing; 

FIG. 2 is a block diagram showing a preferred embodi- 
ment of an imaging devices according to the present inven- 
tion; 

FIG. 3 is a block diagram showing a preferred embodi- 
ment of a computer of the present invention; 

FIG, 4 is a block diagram showing a preferred embodi- 
ment of a Random Access Memory (RAM) of the FIG. 3 
computer; 

FIG. 5 is a block diagram showing a preferred embodi- 
ment of a Read Only Memory (ROM) of the FIG, 3 
computer; 

FIG. 6 is a block diagram showing a preferred embodi- 
ment of an apparatus for increasing a camera image capture 
rate according to the present invention; 

FIG. 7 is a block diagram showing priority levels of 
5Q preferred processes and corresponding image data paths; 

FIG. 8 is a flowchart of preferred method steps for 
implementing RAM Spooler 1 of the present invention; 

FIG. 9 is a flowchart of preferred method steps for 
implementing the Flash Spooler 1 of the present invention; 
55 FIG. 10 is a flowchart of preferred method steps for 
implementing the Image Processing/Compression of the 
present invention; 

FIG. 11 is a flowchart of preferred method steps for 
unplementing the RAM Spooler 2 of the present invention; 
60 and 

FIG. 12 is a flowchart of preferred method steps for 
implementing the Flash Spooler 2 of the present invention. 

DETAILED DESCRIPTION OF THE 
^5 PREFERRED EMBODIMENT 

The present invention comprises an apparatus and method 
for increasing the successive image capture rate of a digital 
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camera and features a series of priority levels, the highest of 18 aad DSP 40. Interface 52 has data lines coupled to both 

which maintains the apparatus in a ready state for capturing external bus 16 and internal bus 66. Processing unit 54 

multiple sets of raw image data. Recently captured raw executes programming instructions stored in ROM 56 and 

images are temporarily diverted to a memory device and the RAM 60 to perform various operations, ROM 56 stores a set 

time-intensive software-based image processing and com- 5 of computer readable program instructions which control 

pression operations are postponed until after the apparatus how processing unit 54 accesses, transforms and outputs the 

has stopped capturing additional sets of image data or until image data. While ROM 56 is employed as a conventional 

processor time becomes available. During a time when the non-volatHe memory device for practicing the present 

apparatus is no longer capturing additional sets of image invention, those skilled in the art will recognize that in 

data, the present invention advantageously performs the lo alternate embodiments ROM 56, could be replaced with a 

image processing and compression operations. As a result, functionally equivalent computer useable medium such as a 

the time delay between, successive image captures is greatly compact disk and drive, a floppy disk and drive, or a flash 

reduced. memory. 

Referring now to FIG. 1, a block diagram of a preferred Input device 58 preferably comprises a series of control 

embodiment of apparatus 10 for increasing an image capture IS buttons which generate signals translated by processing unit 

rate is shown. Apparatus 10 may be used to capture a set of 54 into an image capture request, an operating mode selec- 

image data representing an object 12. Apparatus 10 prefer- tion request, and various control signals for imaging device 

ably comprises an imaging device 14, an external bus 16 and 14. In an alternate embodiment in which computer 18 is a 

a computer 18. Imaging device 14 is optically coupled to discrete computer system, input device 58 also includes a 

object 12 and electrically coupled via external bus 16 to 20 keyboard and mouse-type controller, 

computer 18. Once a photographer has focused imaging i/o Interface 62 is coupled to internal bus 66 and has an 

device 14 on object 12 and, using a capture button or some external port connector for coupling computer 18 with a host 

other means, instructed apparatus 10 to capture an image of computer (not shown) for downloading image data stored in 

object 12, computer 18 commands imaging device 14 via RAM 60 and/or flash memory 64. At the user's choice or 

external bus 16 to capture raw image data representing 25 ^j^^j^ apparatus 10 is completely fiUed with image data, I/O 

object 12. The captured raw image data is transferred over Interface 62 enables the image data to be down-loaded, thus 

external bus 16 to computer 18 which performs various freeing up storage space for future sets of image data. Flash 

image processing functions on the image data before storing memory 64 serves as an additional image data storage area 

it in its internal memory. External bus 16 also passes various and is preferably a non-volatile device, readily removable 

status and control signals between imaging device 14 and and replaceable by a user. Thus, a user who possesses 

computer 18. several flash memories 64 may replace a full flash memory 

Referring now to FIG. 2, a block diagram of a preferred 64 with an empty flash memory 64 to effectively expands the 

embodiment of imaging device 14 is shown. Imaging device picture taking capacity of apparatus 10. In the preferred 

14 preferably comprises a lens 20 having an iris, a filter 22, embodiment of the present invention, flash memory 64 is a 

an image sensor 24, a timing generator 26, an analog signal flash disk. Non-volatile memory 68 stores an image counter 

processor (ASP) 28, an analog-to-digital (A/D) converter 30, whose current value becomes an identifier for each new set 

a digital signal processor (DSP) 40, and one or more motors of image data captured by apparatus 10. The counter is 

32 preferably incremented each time a new image is captured. 

U.S. patent application Ser. No. 08/355,031, entitled "A ^ 1° the preferred embodiment, non-volatile niemory 68 is 

System and Method For Generating a Contrast Overlay as a either an EEPROM or a battery-backed SRAM. 

Focus Assist for an Imaging Device," filed on Dec. 13, 1994 Referring now to FIG. 4, a block diagram of a preferred 

is incorporated herein by reference and provides a detailed embodiment of RAM 60 is shown. RAM 60 is comprised of 

discussion of the preferred elements of imaging device 14. a firame buffer 70, a working memory 72 and a RAM disk 

Briefly, imaging device 14 captures an image of object 12 74. Frame buffer 70 preferably comprises a dedicated space 

via reflected light impacting image sensor 24 along optical of contiguous memory suitable for storing the raw image 

path 34. Image sensor 24 responsively generates a set of raw data generated by image sensor 24. The function of frame 

image data representing the captured image 12. The raw buffer 70 is to store the most recently captured set of raw 

image data is then routed through ASP 28, A/D converter 30 image data untfl computer 18 either stores the raw image 

and DSP 40. DSP 40 has outputs coupled to lines 35, 38 and data in RAM disk 74 or transfers it to an image processing 

42 for controlling ASP 28, motors 32 and timing generator unit. 

26. From DSP 40, the raw image data passes over external RAM disk 74 is a memory area within RAM 60 organized 

bus 16 to computer 18. in a "sectored" format similar to that of conventional hard 

Referring now to FIG. 3, a block diagram of a preferred disk drives. The RAM disk 74 function is to store image 

embodiment of computer 18 is shown. Computer 18 com- 55 data. RAM disk 74, in conjunction with flash memory 64, 

prises a bus interface 52, a processing unit 54, a read-only sets the maximum image holding capacity of apparatus 10. 

memory (ROM) 56, an input device 58, a random access Once both flash memory 64 and RAM disk 74 have been 

memory (RAM) 60, an I/O interface 62, a flash memory 64 fifled with compressed image data, the insertion of a new 

and a non-volatile memory 68 coupled together via an flash memory 64 or down-loading the image data via I/O 

internal bus 66. In the preferred embodiment, computer 18 59 interface 62 will enable apparatus 10 to continue capturing 

is embedded as part of apparatus 10 using a conventional new images. 

architecture. However, those skflled in the art will recognize Working memory 72 is comprised of data cells 76, input 

that in an alternate embodiment, computer 18 may be a queues 78, storage status 80 and temporary buffer 81, each 

discrete computer system. coupled via internal bus 66. Data cells 76 are data structures 

Bus interface 52 is preferably a bi-directional first-in, 65 and each data cell 76 is uniquely associated with particular 

first-out interface for receiving the raw image data and captured image data. A data cell is comprised of a plurality 

imaging device 14 control signals passed between computer of data fields including an image data identifier, a current 
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location and processing requests. The image data identifier 
is of the preferred form "IMXXXXXX.YYY," where 
"XXXXXX" is the image number retrieved from non- 
volatile memory 68 and "YYY" is the image data file type. 
In the preferred embodiment, the image number 5 
"XXXXXX" is not reset, so when images are down-loaded 
to a host computer, image file identifiers will not conflict 
with image files previously down-loaded to the host com- 
puter. However, in an alternate embodiment the image 
number "XXXXXX" could be reset each time image data is 
down-loaded from apparatus 10. Also the "IM" in the image 
identifier may be replaced with "10/' The image data file 
type, "YYY," is preferably either CFA, JPG or PCX CPA 
refers to a set of raw image data and both JPG and PCT refer 
to a sets of compressed image data. 

The image data's current location data field stores either 
a "Raw Image Data In Frame Buffer" flag, a "Raw Image 
Data In RAM Disk" flag, a "Compressed Image Data In 
RAM Disk" flag, a "Raw Image Data In Flash memory" flag, 
a "Compressed Image Data In Flash memory" flag, or a 
"Compressed Image Data In Temporary Buffer" flag. The 20 
image data's processing request data field stores either a 
"Request Deletion Of Image Data" flag and/or a "Stop 
Processing Of Image Data" flag. Input queues 78 are data 
structures comprised of a plurality of data cell "pointers" 
each corresponding to data cells 76. In the preferred 25 
embodiment, input queues operate on a first-in/first-out 
basis. 

Storage status 80 is a data structure describing the remain- 
ing available memory in both RAM disk 74 and flash 
memory 64. Storage status 80 contains the following four 30 
conditional variables: "RAM Disk Raw File Space," "RAM 
Disk Compressed File Space," "Flash Memory Raw File 
Space" and "Flash Memory Compressed File Space." Each 
of the four conditional variables is set to one of three values: 
FULL, ALMOST FULL or OK. If the variable is set to 35 
"OK," then space is available for that particular file type 
(i.e., a raw file or a compressed file) on that particular 
storage resource (i.e., RAM disk 74 or flash memory 64). If 
the variable is set to "ALMOST FULL" then space is not 
currently available for that particular file type on that 40 
particular storage resource, but there will be space in the 
future. If the variable is set to "FULL" then, absent an 
increase in available space on storage resources (due, for 
example, to downloading data or replacing storage units), no 
space is available for that particular file type on that par- 45 
ticular storage resource, nor will space be available in the 
future. Temporary buffer 81 of working memory 72 is 
provided for temporarily storing data and/or program code. 

Referring now to FIG. 5, a block diagram of a preferred 
embodiment of ROM 56 is shown. ROM 56 preferably 50 
contains code for processes 82 through 96, including a 
control application (CA) 82, a RAM spooler 1 (RSI) 84, a 
flash memory spooler 1 (MSI) 86, image processing/ 
compression (IPC) 88, a RAM spooler 2 (RS2) 90, a flash 
memory spooler 2 (MS2) 92, a file manager 94, and an 55 
operating system 96, each coupled via internal bus 66. In 
alternate embodiments, the FIG. 5 processes 82 through 96 
may be stored in various computer memory types other than 
ROM 56, 

A "spooler" is herein defined as a routine for transferring 60 
data from one process or device to a second process or 
device. RAM spooler 1 (84) transfers raw image data into 
RAM disk 74, and flash memory spooler 1 (86) transfers raw 
image data into flash memory 64, RAM spooler 2 (90) 
transfers compressed image data into RAM disk 74 or to I/O 65 
interface 62, and flash memory spooler 2 (92) transfers 
compressed image data into flash memory 64. 
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Control application 82 preferably comprises program 
instructions for controlling the operation of apparatus 10 
which are executed using processing unit 54. For example, 
control application 82 creates and maintains data cells 76. 
Image processing/compression 88 compresses the raw 
image data to maximize the image-carrying capacity of 
apparatus 10, and also processes the raw image data to 
permit readily displaying the captured image data on a host 
computer. In the preferred embodiment, processes 82 
through 96 are comprised of a series of software steps 
implemented on top of a multithreaded operating system and 
may therefore run in parallel operation. 

FIG. 6 is a block diagram showing a preferred embodi- 
ment of apparatus 10 for increasing a camera image capture 
rate. In FIG. 6, frame buffer 70 receives and stores raw 
image data previously captured by imaging device 14. 
Frame buffer 70 then provides the raw image data via fine 
100 to rotate process 95 which is described in detail in 
co-pending U.S. patent application Ser. No. 08/588,210, 
entitled "Apparatus and Method for Rotating the Display 
Orientation of a Captured Image," filed on Jan. 19, 1996, 
which is hereby incorporated by reference. 

Process 95 rotates the captured image if necessary and 
then transfers control of the raw image data to RAM spooler 
1 (84) using line 102. Alternately, if RAM disk 74 is fuU, 
rotate process 95 may transfer control of the raw image data 
directly to image processing/compression (IPC) 88 using 
line 118, If RAM spooler 1 (84) receives control of the raw 
image data, it then stores the raw image data into RAM disk 
74 using line 104. 

Flash spooler 1 (86) may then access the raw image data 
from RAM disk 74 via line 106 and store it into flash 
memory 64 using line 108. Alternately, if flash memory 64 
is full, RAM disk 74 may provide the raw image data 
directly to IPC 88 using line 114. If flash spooler 1 (86) 
stores the raw image data into flash memory 64, then IPC 88 
typically accesses the stored raw image data using line 110 
and processes the raw data to responsively obtain com- 
pressed image data, 

IPC 88 may bypass RAM spooler 2 (90) and store the 
compressed data directly to RAM disk 74 via fine 115, or 
alternately, if RAM disk 74 is temporarily full, IPC 88 may 
write the compressed data to temporary RAM buffer 81 via 
line 85. RAM spooler 2 (90) may then access the com- 
pressed image data via line 87 and write the accessed data 
into RAM disk 74 via fine 104. RAM spooler 2 (90) may 
also download the compressed image data to I/O interface 
62 using fine 116. Once the compressed data is in RAM disk 
74, flash spooler 2 (92) then accesses the data via fine 106 
and writes the compressed data into flash memory 64. 

The present invention may thus process and store a 
sequence of captured images received from imaging device 
14. Although the above example traces the typical data path 
for a single captured image, the present invention may 
readily operate on a plurality of captured images progressing 
through various stages of apparatus 10. Therefore, multiple 
sets of image data may exist simultaneously within com- 
puter 18. The current processing stage for a specific set of 
image data is preferably indicated by flags located in the 
image data's unique data ceU 76. 

FIG. 7 is a block diagram showing priority levels for 
processes 84 through 92 of the preferred embodiment with 
corresponding image data routing paths. Background pro- 
cesses 84 through 92 are preferably allotted processing unit 
54 time depending on their priority level. This priority level 
is related to the goal of rapidly emptying frame buffer 70 to 
enable rapid capture of successive sets of image data. 
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Control application 82 transfers raw image data from request bit in data cell 76. If the "stop processing" request 

imaging device 14 to frame buffer 70 and may supersede any is present, step 206 returns data cell 76 to control application 

of background processes 84 through 92. The background 82 and returns the FIG. 8 process back to step 202. If the 

process with the highest priority is RAM spoolerl (84) which request is not present, step 208 determines whether RAM 

moves raw image data out of frame buffer 70 to RAM disk 5 (^\sk 74 or flash memory 64 are available. If not available, 

74. The second highest priority is flash memory spooler 1 gj^p 210 sends the raw image data directly to IPC 88 and 

(86) which moves raw image data out of RAM disk 74 to returns the FIG. 8 process back to step 202. 

flash memory 64. The third highest priority is Image ^.^ ^^^^ memory 64 are available, step 

Processing/Compression 88 which accesses raw rniage data ^12 determines whether the raw image data is stored in 

and responsively processes and compresses the image data ^^^^ ^^^^^^^ ^^^^^^ 74^ 

before storing it as compressed image data mto RAM disk 326 sends the raw image data to flash spooler 1 (86) and 

74, or if RAM disk 74 is full, into temporary RAM buffer 81 ^^^^^^ g ^^^^^^^ ^^^p 202. If the data is not 

of working memory 72. The fourth highest pnonty is RAM ^^^^^^ ^ ^^y. ^^^^ 214 determines whether a 

spooler 2 (90) which, if necessary, may move compressed .^^g^„ ^^^^^^^ ^^^^^^^ checking a correspond- 

image data out of working memory 72 mto RAM disk 74 ^5 . ^ ^ ^^^^ ^^^^^^^ ^ ^^^^^^^^ ^tep 

The lowest priority is flash memory spooler 2 (92) which ^16 releases frame buffer 70 to accept incoming raw image 

moves the compressed unage data out of RAM disk 74 into ^^^^ ^^^^ imaging device 14. Step 206 then returns data cell 

flash memory 64. Those skilled m the art wifl recognize that ^^^^^^^ appMcation 82 and the FIG. 8 process returns 

either a greater or a lesser number of priority levels than the 202. If the "delete image" request is not present, step 

preferred five may be used m the present invention. Also, 20 218 determines whether there is (or wiU be) space on RAM 

alternate embodiments may establish different criteria for checking storage status 80, as described above in 

routing the captured image data, dependmg upon memory conjunction with FIG. 4. If there is (or will be) space, step 

resources available and/or the maximum image capture rate ^20 waits for a "space available now" signal before step 222 

desired. File manager process 94 and operatmg system ^^^^^^^ ^.^^ If ^^ep 218 

process 96 are not assigned specific priority levels since they 25 determines that RAM disk 74 has no space, then step 228 

either operate in the background or under mterrupt condi- determines whether flash memory 64 has (or wifl have) 

space by checking storage status 80. If flash memory 64 has 

Processes 82 through 92 preferably each has a respective ^^^^^^ ^^^^^ condition exists. Step 230 therefore 

input queue 78(a) through 78(/) which operates on a first- ^etarns data ceU 76 to control appflcation 82 and remms the 

in/first-out basis. If one of processes 82 through 92 has a data 30 g process to step 202. If flash memory 64 has (or wifl 

cell 76 pointer in its input queue, then only that process can ^^^^y ^^^^^ g^ep 232 waits for a "space available now'' 

access and perform operations on the image data associated ^^^^^ ^^^^^^ ^^^^ 234 creates the file to write on flash 

with that particular data cefl 76. The data ceU pointers are memory 64 

passed between processes 82 through 92 in a specific order ^24, the image is rotated if necessary, and RAM 

until the original raw image data has been My processed, 35 ^ (^4) ^ data to the created file 

compressed and stored m a memory resource. ^^^^^^^ ^^^^ ^^^^^^ ^ 

The pnonty level scheme mtroduced above may block ^^^^ j ^^^.^^ ^4 S^^p 226 transfers 

one or more processes 84 through 92 even though a data cell ^^^^^^ j ^^^^^ PIq g process 

76 pointer is in its input queue 78. For example smce ^ step 202 to wait for another message on its input queue 78. 

moving raw image data out of frame buffer 70 has the 40 ^ . „ , ^ ^ -, .1. j . r 

highesfprionty^if auserrepeatedlycapturesimagesinrapid . ^ ^ A^^^^^t of preferred method steps for 

succession, RAM spooler 1 (84) will continue to operate implementing flash spooler 1 (86) according to the present 

until RAM disk 74 becomes filled with raw image data. f ^SHT^ ""T 1 fT X f'fl 

While RAM spooler 1 (84) is operating, aU of the other ^Voolcr 1 (86). In step 302, flash spooler 1 (86) waits for a 

lower priority processes 86 through 92 wfll be "blocked" 45 9^^^^^ ^A^^^^f ^dv^ncmg to step 304. 

(i.e., idled), even though some of the lower priority pro- ^^'^^ ^Voohr 1 (86), m step 304 detemiines whether a s op 

cesses 86 through 92 may stifl have data ceU 76 pointers in processing" request is present If the request is present step 

their input queues 78. This blocking of lower priority 306 returns data cell 76 to control a^^^^^ 

processes applies to afl priority levels. For example, opera- FI^. 9 process back to step 302. 

tion of flash memory spoolerl (86) wifl block image 50 If the request is not present, step 308 determines whether 

processing/compression 88, RAM spooler 2 (90) and flash the raw image data is stored in flash memory 64. If the data 

memory spooler 2 (92), and operation of image processing/ is already stored in flash memory 64, step 324 sends the raw 

compression 88 wifl block RAM spooler 2 (90) and flash image data to IPC 88 and returns the FIG. 9 process to step 

memory spooler 2 (92), and so on, until the image data has 302. If the data is not stored in flash memory 64, step 310 

been fully processed, compressed and stored in memory. 55 determines whether a "delete image" request is present. If 

Furthermore, if a lower priority ROM process is currently the request is present, step 312 deletes the file in RAM disk 

operating and a higher priority ROM process requires pro- 74. Step 306 then sends data cefl 76 to control application 82 

cessing unit 54, then the lower priority ROM process is and the FIG. 9 process returns to step 302. If the "delete 

immediately blocked until the higher priority ROM process image" request is not present, step 314 determines whether 

has completed its operations. 60 raw image data is stored in RAM disk 74, If the data is 

FIG. 8 is a flowchart of preferred method steps for not stored in RAM disk 74, step 316 signals an error, returns 

implementing RAM spooler 1 (84) according to the present data cefl 76 to control application 82 and returns the FIG. 9 

invention. In step 200, processing unit 54 initializes RAM process back to step 302. 

spooler 1 (84). RAM spooler 1 (84) waits 202 for a message If the raw im^e data is stored in RAM disk 74, step 318 

or pointer on its input queue 78. Once a message is received, 65 determines whether flash memory 64 has (or wifl have) 

RAM spooler 1 (84), determines 204 whether a "stop space. If flash memory 64 has no space, step 324 sends data 

processing" request is present by checking a corresponding cell 76 to image processing/compression and then the FIG. 



